<template>
  <div>
    <ele-pro-table
      :height="640"
      :border="true"
      :virtual="true"
      row-key="userId"
      :columns="columns"
      :datasource="datasource"
      :span-method="spanMethod"
      :toolbar="{ theme: 'default' }"
      :show-overflow-tooltip="true"
      :export-config="{ fileName: '成绩数据' }"
      :pagination="{
        pageSize: 20,
        pageSizes: [20, 40, 80]
      }"
    />
  </div>
</template>

<script setup>
  import { ref } from 'vue';
  import { pageUserScores } from '@/api/example';

  /** 表格列配置 */
  const columns = ref([
    {
      type: 'index',
      columnKey: 'index',
      width: 50,
      align: 'center'
    },
    {
      prop: 'userName',
      label: '姓名',
      align: 'center'
    },
    {
      prop: 'courseName',
      label: '课程',
      align: 'center'
    },
    {
      prop: 'score',
      label: '得分',
      align: 'center'
    }
  ]);

  /** 表格数据源 */
  const datasource = () => {
    return pageUserScores();
  };

  /** 合并表格单元格 */
  const spanMethod = ({ row, column }) => {
    return [
      row[`${column.prop}RowSpan`] ?? 1,
      row[`${column.prop}ColSpan`] ?? 1
    ];
  };
</script>
